

#### การจัดองค์การคอมพิวเตอร์

### **Multi-Bit Buses**

31110321 Computer Organization สำหรับนักศึกษาชั้นปีที่ 2 สาขาวิชาวิศวกรรมคอมพิวเตอร์

> ทรงฤทธิ์ กิติศรีวรพันธุ์ songrit@npu.ac.th สาขาวิชาวิศวกรรมคอมพิวเตอร์ มหาวิทยาลัยนครพนม

# Lecture plan

- 1.1 บูลีน ลอจิก
- 1.2 การสังเคราะห์ฟังก์ชั่นบูลีน
- 1.3 ลอจิกเกต
- •1.4 ภาษา HDL
- 1.5 โปรแกรมจำลอง Hardware Simulation
- 1.6 โค้ด HDL แบบ Multi-Bit Buses
- 1.7 โปรเจ็ค 1

# Structure HDL

## **Parts**

```
PARTS:
internal chip part;
internal chip part;
...
internal chip part;
```

# **Internal Pins**

```
Part1 (..., out=v);
Part2 (in=v, ...);
Part3 (a=v, b=v, ...);
```

# Input/Output Pins

- Input pin มี fan-in เป็น 1 เท่านั้น
  - ∘ And (in1=v, in2=v,...) → **T**o
  - ∘ And (in1=v, in1=u,..) → ไม่ได้
- Output pin
  - ส่งต่อไป input chip อื่นได้
  - ส่งออกเป็น internal pin ได้

# บัส (buses)

- •ชื่อ pin เดียวแต่ทำงานหลายบิท
- เรียงจากบิทมากไปหาน้อย sel[7],[6],...[0]

```
CHIP Foo {
IN in[8] // 8-bit input
OUT out[8] // 8-bit output

PARTS:
// ฟังก์ชัน
}
```

## **Buses**

#### PARTS:

Foo(in[2..4]=v, in[6..7]=true, out[0..3]=x, out[2..6]=y)

#### PARTS:

Foo(in[2..4]=v, in[6..7]=true, out[0..3]=x, out[2..6]=y)

Now, let us assume that the logic of the Foo chip returns the following output:

In that case, the connections out[0..3]=x and out[2..6]=y will yield:

# Coming up: W1.6 Project overview

โปรเจ็คสัปดาห์ 1